import { Button, Form, Input, message } from 'antd';
import React from 'react';
import axios from '../../utils/request'
import { useNavigate } from 'react-router-dom'
import './index.css'

const App: React.FC = () => {
  const navigate = useNavigate()
  const onFinish = (values: any) => {
  axios.get(`/users?username=${values.username}&password=${values.password}&roleState=true&_expand=role`)
  .then(({data}) => {
    if(data.length === 0){
      return message.error('登录失败')
    }
    localStorage.setItem('token', JSON.stringify(data[0]))
    navigate('/home')
  })
  };

  const onFinishFailed = (errorInfo: any) => {
    console.log('Failed:', errorInfo);
  };

  return (
    <div className='login-container'>
      <div className="login-form">
      <Form
      name="basic"
      labelCol={{ span: 8 }}
      wrapperCol={{ span: 16 }}
      initialValues={{ remember: true }}
      onFinish={onFinish}
      onFinishFailed={onFinishFailed}
      autoComplete="off"
    >
      <Form.Item
        label="Username"
        name="username"
        rules={[{ required: true, message: 'Please input your username!' }]}
      >
        <Input />
      </Form.Item>

      <Form.Item
        label="Password"
        name="password"
        rules={[{ required: true, message: 'Please input your password!' }]}
      >
        <Input.Password />
      </Form.Item>

      <Form.Item wrapperCol={{ offset: 8, span: 16 }}>
        <Button type="primary" htmlType="submit">
          Submit
        </Button>
      </Form.Item>
    </Form>
      </div>
    </div>
  );
};

export default App;